<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "https://www.w3.org/TR/html4/loose.dtd">
<html lang="zh-CN"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><meta http-equiv="Content-Language" content="zh-CN"><link href="stylesheet.css" media="all" rel="stylesheet" type="text/css">
<title>锁和索引</title>
<script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?d286c55b63a3c54a1e43d10d4c203e75"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script>
</head><body class="SECT1">
<div>
<table summary="Header navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><th colspan="5" align="center" valign="bottom">PostgreSQL 8.2.3 中文文档</th></tr>
<tr><td width="10%" align="left" valign="top"><a href="applevel-consistency.html" accesskey="P">后退</a></td><td width="10%" align="left" valign="top"><a href="mvcc.html">快退</a></td><td width="60%" align="center" valign="bottom">章12. 并发控制</td><td width="10%" align="right" valign="top"><a href="mvcc.html">快进</a></td><td width="10%" align="right" valign="top"><a href="performance-tips.html" accesskey="N">前进</a></td></tr>
</table>
<hr align="LEFT" width="100%"></div>
<div class="SECT1"><h1 class="SECT1"><a name="LOCKING-INDEXES">12.5. 锁和索引</a></h1><a name="AEN16713"></a>
<p>尽管 PostgreSQL 提供对表数据访问的非阻塞的读/写，但并非所有 PostgreSQL 里实现的索引访问模式都能够进行非阻塞读/写。不同的索引类型按照下面方法操作：</p>
<div class="VARIABLELIST">
<dl>
<dt>B-tree 和 GiST 索引</dt>
<dd><p>短期的页面级共享/排他锁用于读/写访问。锁在索引行被插入/抓取后立即释放。这种索引类型提供了无死锁条件的最高级的并发性。</p></dd>
<dt>Hash 索引</dt>
<dd><p>Hash 桶级别的共享/排他锁用于读/写访问。锁在整个 Hash 桶处理完成后释放。 Hash 桶级锁比索引级的锁提供了更好的并发性但是可能产生死锁，因为锁持有的时间比一次索引操作时间长。</p></dd>
<dt>GIN 索引</dt>
<dd><p>短期的页面级共享/排他锁用于读/写访问。锁在索引行被插入/抓取后立即释放。但要注意的是一个 GIN 索引值的插入通常导致几个每行几个索引键的插入，因此 GIN 可能为了插入一个值而做大量的工作。</p></dd>
</dl>
</div>
<p>目前，B-tree 索引为并发应用提供了最好的性能。因为它还有比 Hash 索引更多的特性，在那些需要对标量数据进行索引的并发应用中，我们建议使用 B-tree 索引类型。在处理非标量类型数据的时候，B-tree 就没什么用了，应该使用 GiST 或 GIN 索引。</p>
</div>
<div>
<hr align="LEFT" width="100%">
<table summary="Footer navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><td width="33%" align="left" valign="top"><a href="applevel-consistency.html" accesskey="P">后退</a></td><td width="34%" align="center" valign="top"><a href="index.html" accesskey="H">首页</a></td><td width="33%" align="right" valign="top"><a href="performance-tips.html" accesskey="N">前进</a></td></tr>
<tr><td width="33%" align="left" valign="top">应用层数据完整性检查</td><td width="34%" align="center" valign="top"><a href="mvcc.html" accesskey="U">上一级</a></td><td width="33%" align="right" valign="top">性能提升技巧</td></tr>
</table>
</div>
</body></html>